/**
 * 70. 爬楼梯
 */
public class ClimbStairs {
    public int climbStairs(int n) {
        // dp[i]表示到达i + 1这个台阶有多少种方式
        int[] dp = new int[n];
        if (n > 0) {
            dp[0] = 1;
        }
        if (n > 1) {
            dp[1] = 2;
        }
        for (int i = 2; i < n; i++) {
            // 当前一步所有方式数取决于前面两步的方式数
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n - 1];
    }
}
